

/*
 * @lc app=leetcode.cn id=20 lang=cpp
 *
 * [20] 有效的括号
 *
 * https://leetcode-cn.com/problems/valid-parentheses/description/
 *
 * algorithms
 * Easy (44.54%)
 * Likes:    3086
 * Dislikes: 0
 * Total Accepted:    986.7K
 * Total Submissions: 2.2M
 * Testcase Example:  '"()"'
 *
 * 给定一个只包括 '('，')'，'{'，'}'，'['，']' 的字符串 s ，判断字符串是否有效。
 *
 * 有效字符串需满足：
 *
 *
 * 左括号必须用相同类型的右括号闭合。
 * 左括号必须以正确的顺序闭合。
 *
 *
 *
 *
 * 示例 1：
 *
 *
 * 输入：s = "()"
 * 输出：true
 *
 *
 * 示例 2：
 *
 *
 * 输入：s = "()[]{}"
 * 输出：true
 *
 *
 * 示例 3：
 *
 *
 * 输入：s = "(]"
 * 输出：false
 *
 *
 * 示例 4：
 *
 *
 * 输入：s = "([)]"
 * 输出：false
 *
 *
 * 示例 5：
 *
 *
 * 输入：s = "{[]}"
 * 输出：true
 *
 *
 *
 * 提示：
 *
 *
 * 1
 * s 仅由括号 '()[]{}' 组成
 *
 *
 */

// @lc code=start

class Solution
{
public:
    bool isValid(string s)
    {
        stack<char> stk;
        auto it = s.begin();
        while (it != s.end())
        {
            if (*it == '(' || *it == '[' || *it == '{')
            {
                stk.push(*it);
                it++;
            }
            else if (*it == ')')
            {
                if (stk.empty() == true)
                    return false;
                if (stk.top() == '(')
                {
                    stk.pop();
                    it++;
                }
                else
                    return false;
            }
            else if (*it == ']')
            {
                if (stk.empty() == true)
                    return false;
                if (stk.top() == '[')
                {
                    stk.pop();
                    it++;
                }
                else
                    return false;
            }
            else
            {
                if (stk.empty() == true)
                    return false;
                if (stk.top() == '{')
                {
                    stk.pop();
                    it++;
                }
                else
                    return false;
            }
        }
        if (stk.empty() == true)
            return true;
        else
            return false;
    }
};
// @lc code=end
